| Total Complexity | 8 |
| Total Lines | 33 |
| Duplicated Lines | 0 % |
| Coverage | 100% |
| Changes | 0 | ||
| 1 | class Diff { |
||
| 2 | constructor(currentArray, otherArray, total) { |
||
| 3 | 2 | this.currentArray = currentArray; |
|
| 4 | 2 | this.otherArray = otherArray; |
|
| 5 | 2 | this.total = total; |
|
| 6 | } |
||
| 7 | |||
| 8 | get differenceArray() { |
||
| 9 | 2 | return this.currentArray.filter( |
|
| 10 | 6 | (value) => this.otherArray.indexOf(value) < 0 |
|
| 11 | ); |
||
| 12 | } |
||
| 13 | |||
| 14 | get differenceArrayB() { |
||
| 15 | 2 | if (!this.total) { |
|
| 16 | 1 | return []; |
|
| 17 | } |
||
| 18 | |||
| 19 | 1 | return this.otherArray.filter( |
|
| 20 | 3 | (value) => this.currentArray.indexOf(value) < 0 |
|
| 21 | ); |
||
| 22 | } |
||
| 23 | |||
| 24 | get compare() { |
||
| 25 | 2 | return this.differenceArray.concat(this.differenceArrayB); |
|
| 26 | } |
||
| 27 | |||
| 28 | static create(currentArray, otherArray, total) { |
||
| 29 | 2 | const differ = new Diff(currentArray, otherArray, total); |
|
| 30 | |||
| 31 | 2 | return differ.compare; |
|
| 32 | } |
||
| 33 | } |
||
| 34 | |||
| 38 |